草庐IT

javascript - angular.js 应用程序中的多个 View

全部标签

ruby - 如何在 Ruby 应用程序中找到未使用的方法?

我有一个包含很多类/模块的Ruby应用程序,其中一些没有被使用。有没有一种简单的方法可以找出是哪一个?我想做一个配置文件,然后使用它的输出。还有其他想法吗? 最佳答案 像rcov这样的覆盖工具可能会有所帮助。https://github.com/relevance/rcov当您发现测试未涵盖的方法时,您应该为它们编写测试或查明它们是否被使用。删除未使用的方法是重构的一部分,如果您有太多的类可能会产生代码异味,也需要重构。 关于ruby-如何在Ruby应用程序中找到未使用的方法?,我们在S

ruby - ruby 中的 fork 和线程

我在一台有两个处理器的机器上运行一个程序,当我做一个fork时,子线程是作为native线程创建的,或者它就像一个绿色线程/协程。子进程是与父进程同时运行还是只是并行运行? 最佳答案 fork()的工作一般是生成一个新的、独立的进程,复制页表,并将调用fork()的进程拥有的所有页面标记为该进程中的写时复制。然后,fork()在两个进程中返回(返回值让相应的进程知道它是哪个进程)。在具有多个处理器(或处理器核心)的系统上,您可以正常(假设您确实有一个支持SMP的系统,cpu亲和性不会阻止它)期望这两个进程使用这两种处理器,但您不能严

ruby - 模块中的 @ 和 @@ 有什么区别?

假设一个模块是包含的,而不是扩展的,那么模块实例变量和类变量有什么区别?我看不出两者有什么区别。moduleM@foo=1defself.foo@fooendendpM.foomoduleM@@foo=1defself.foo@@fooendendpM.foo我一直在模块中使用@作为@@,我最近看到其他代码在模块中使用@@。然后我想我可能一直在错误地使用它。既然我们不能实例化一个模块,那么@和@@对于一个模块来说肯定没有区别。我错了吗?--------------------添加了以下内容--------------------为了回答关于评论和帖子的一些问题,我还测试了以下内容。mo

ruby-on-rails - 如何将 Rails 中的目录加载列入黑名单?

我想在运行测试时禁用ActiveAdmin。所以我将require:false添加到Gemfile并检查ifdefined?(ActiveAdmin)在路由和初始化程序中。但Rails仍然从app/admin加载模型,因此我收到类似于/app/admin/admin_user.rb:1:in':uninitializedconstant的错误ActiveAdmin(名称错误)`将app/admin目录列入“黑名单”以防止加载的最佳方法是什么? 最佳答案 #config/environments/test.rbpath_rejecto

ruby - 部署到 heroku 的 Watir 应用程序

我正在尝试将应用程序部署到使用Watirwebdriver的Heroku。它在本地成功运行。根据这个问题的答案:CanyoudeployWatironHerokutogenerateHTMLSnapshots?Ifso,how?,你能行的。我按照这个答案https://stackoverflow.com/a/21267376/3192470中的步骤操作.我的app.rb看起来像这样:require"sinatra"require"rubygems"require"shotgun"require"rake"require"watir"get'/sending_out'dobrowser=

ruby-on-rails - 从 Rails 3 中的默认 ActionController LogSubscriber 修改日志格式和内容

上下文:在一个Rails3项目中,我想自定义(大量)来自ActionController的“Processing”和“Completedin”日志行的格式和内容。这是为了让它们与旧版Rails2.3应用程序的(也是自定义的)格式相匹配,从而允许重复使用各种分析工具。使它们成为固定字段(通过在必要时使用占位符)还可以更容易地使用(比如)awk对它们进行临时查询,或者将它们加载到数据库或splunk中而无需智能解析。我通过forkrails和patching快速而严厉地实现了这个目标有问题的LogSubscriber,但我现在希望以正确的方式做到这一点。这是我认为我想做的事情:创建一个Lo

ruby - 在 heroku cedar 堆栈上部署 sinatra 应用程序(使用 config.ru)

我正在尝试重构我的sinatra代码以将我的主文件分成单独的文件,使用来自thisresponse的一些技巧,我在部署到heroku时遇到了麻烦。以前我没有config.ru文件,只是使用了我的Procfile,它是:web:bundleexecrubyweb.rb-p$PORT根据thisarticle.从重构开始,我现在将Procfile更改为web:bundleexecthin-Rconfig.rustart-p$PORT我的config.ru文件是root=::File.dirname(__FILE__)require::File.join(root,'web')runMyAp

Ruby rails - 如何找到多个选项?

我想根据多个参数查找记录。并且这些参数有多个选项。As"SELECTsomethingFROMmytableWHEREuser_name="xyz"andstatus=("Active"OR"Deleted")我如何将其转换为Rails语句?Person.find_by_user_name_and_status(user_name,status)#thisdoesn'ttaketheORoperator 最佳答案 我现在无法测试,但你试过了吗?Person.find_all_by_user_name_and_status(user_

ruby-on-rails - activesupport 回调中的堆栈级别太深

我在Rails3应用程序中收到SystemStackError。我拥有的所有信息都是无用的一行堆栈跟踪(从日志中获取):SystemStackError(stackleveltoodeep):activesupport(3.2.3)lib/active_support/callbacks.rb:409所以问题是我如何查看完整的堆栈跟踪?注意:我不关心为什么会发生这种情况,我只想知道它发生在何处。使用:Rails3.2.3,Unicorn。谢谢。 最佳答案 如果您在before_save或after_save中更新事件记录,它将继续循

ruby - 当应用程序关闭时,我要在 Sinatra 中的什么位置放置要执行的代码?

我正在为我的网络应用程序使用Sinatra。当我的应用程序关闭时,我有一些要执行的清理代码。Sinatra中是否有针对此的Hook,还是我必须使用单独的机制? 最佳答案 看Kernel#at_exit,如果您在主应用程序文件中的某处定义这样的block,我不明白为什么它不能在Sinatra应用程序中工作。更新:根据matt的评论,您必须在要求Sinatra之前定义您的at_exit处理程序。 关于ruby-当应用程序关闭时,我要在Sinatra中的什么位置放置要执行的代码?,我们在Sta